package edu.wust;

import java.math.BigInteger;

import static java.lang.String.*;

public class exam43 {
    public static void change(int[] arr){
        int index1=0,index2=0;
        for(int i=arr.length-2;i>=0;i--){
            if(arr[i]<arr[i+1]){
                index1=i;
                break;
            }
        }
        for(int i=arr.length-1;i>=0;i--){
            if(arr[i]>arr[index1]){
                index2=i;
                break;
            }
        }
        swap(arr,index1,index2);
        range(arr,index1+1);
    }
    public static void range(int[] arr,int n){
        for(int i=n;i<arr.length-1;i++){
            for(int j=n;j<arr.length-1;j++){
                if(arr[j]>arr[j+1]){
                    swap(arr,j,j+1);
                }
            }
        }
    }
    public static void swap(int[] n,int x,int y){
        int temp=n[y];
        n[y]=n[x];
        n[x]=temp;
    }
//以上是全排列

    public static boolean stringdivide(int[] arr){
        int temp=arr[1]*100+arr[2]*10+arr[3];
        if(temp%2!=0)
            return false;
        temp=temp%100;
        temp=temp*10+arr[4];
        if(temp%3!=0)
            return false;
        temp=temp%100;
        temp=temp*10+arr[5];
        if(temp%5!=0)
            return false;temp=temp%100;
        temp=temp*10+arr[6];
        if(temp%7!=0)
            return false;temp=temp%100;
        temp=temp*10+arr[7];
        if(temp%11!=0)
            return false;temp=temp%100;
        temp=temp*10+arr[8];
        if(temp%13!=0)
            return false;temp=temp%100;
        temp=temp*10+arr[9];
        if(temp%17!=0)
            return false;
        return true;
    }
    public static void main(String[] args) {
       int[] arr=new int[10];
       for(int i=0;i<10;i++)
           arr[i]=i;
       int end=1;
       BigInteger sum=BigInteger.ZERO;
       for(int i=2;i<=10;i++)
           end*=i;
       for(int i=0;i<end;++i){//1406357289
           if(stringdivide(arr)){
               String s="";
               for(int j=0;j<10;j++)
                   s+=valueOf(arr[j]);
               System.out.println(s);
               sum=sum.add(new BigInteger(s));
           }
           change(arr);
       }
       System.out.println(sum);
    }
}

